

# Laboratory Exercise #3 Structural Modeling of Combinational Circuits

| Name: | Group:  |
|-------|---------|
|       | O. Gup: |

## **Target Course Outcomes:**

**CO1:** Create descriptions of digital hardware components such as in combinational and sequential circuits using synthesizable Verilog HDL constructs.

CO2: Verify the functionality of HDL-based components through design verification tools.

## **Intended Learning Outcomes:**

- Create design entry of a combinational circuit using structural modeling in Verilog HDL code
- Synthesize the Verilog HDL design entry
- Simulate the designed circuit using a testbench file

## Supplement:

This exercise requires a basic understanding of the Intel Quartus Prime design flow with ModelSim functional verification, as detailed in Units 1-2 and Laboratory Exercises #1-2. It is also expected that Laboratory Exercise #2 has already been completed before performing this exercise.

#### Instructions:

Perform this hands-on laboratory exercise after attending/watching the onsite/online lecture for Unit 3. This activity is intended to be done individually.

#### Exercise 3A: 2x4 Decoder

Under a new project, create a Verilog HDL description of a **2-to-line decoder with active-high enable (E) signal** using **gate primitives** and **structural modeling**. Use the entity diagram and truth table below for reference. For structural modeling, derive the Boolean functions and draw the logic diagram of the circuit. Synthesize the design. (In the laboratory report, don't forget to include the solutions in obtaining the Boolean functions/logic diagram.)

**Truth Table:** 



Figure 1.Entity Diagram of 2x4 Decoder

| Inp | Output |      |
|-----|--------|------|
| Е   | Α      | D    |
| 0   | XX     | 0000 |
| 1   | 00     | 0001 |
| 1   | 01     | 0010 |
| 1   | 10     | 0100 |
| 1   | 11     | 1000 |

After the design synthesis, create a simulation (testbench) file to the project. Simulate and verify the results. Show both a simulation log (standard output) and simulation waveform (timing diagram) in the laboratory report.



**Test Cases for Simulation:** Include ALL possible input combinations for **A** and vary the **E** values.

#### **Evaluation:**

| Level                           | 1.0                                                                                                                                                                                                                                                               | 2.0                                                                                                                                                                                                                                                             | 3.0                                                                                                                                                                                                                                                                      | 5.0                                                                                | Rating |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------|
| Criteria                        | Outstanding                                                                                                                                                                                                                                                       | Competent                                                                                                                                                                                                                                                       | Marginal                                                                                                                                                                                                                                                                 | Not Acceptable                                                                     | Rating |
| CO1: Verilog<br>Design Entry    | Verilog HDL description is correct and follows specified instructions.                                                                                                                                                                                            |                                                                                                                                                                                                                                                                 | Verilog HDL description is correct but DID NOT follow the specified instructions.                                                                                                                                                                                        | NO Verilog HDL<br>description is presented<br>or the design entry is<br>INCORRECT. |        |
| CO1: Design<br>Synthesis        | Verilog HDL description is synthesized and compiled with NO issues (with 0-1 warning). There is clear evidence in the lab report that supports this result.                                                                                                       | Verilog HDL description is synthesized and compiled with MINOR issues on constructs (with 2-3 warnings). There is clear evidence in the lab report that supports this result.                                                                                   | Verilog HDL description is synthesized and compiled with MAJOR issues on constructs (with 4 or more warnings). There is evidence in the lab report that supports this result.                                                                                            | Simulation has FAILED or there is NO evidence showing a successful simulation.     |        |
| CO2: Verilog<br>Testbench Entry | Verilog HDL testbench is correct and follows specified instructions. ALL possible input combinations or AMPLE test stimuli are included to generate sufficient and verifiable output results.                                                                     |                                                                                                                                                                                                                                                                 | Verilog HDL testbench is correct but DID NOT follow specified instructions. Possible input combinations may be INCOMPLETE or test stimuli are NOT SUFFICIENT included to generate verifiable output results.                                                             | NO Verilog testbench is presented or INCOMPLETE.                                   |        |
| CO2: Functional<br>Verification | Simulation of the synthesized design is functional with NO issues and shows ALL correct and expected results. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE but are ALL correct. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE or there may be INCORRECT results. NO analysis is made with NO image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation has FAILED or there is NO evidence showing a successful simulation.     |        |

## Exercise 3B: 3x8 Decoder

Using the **2x4 decoder** in Exercise 3A, derive and create a **structural description** of a **3-to-8-line decoder with active-high enable** (**E**). Draw the block diagram of the structural design. Synthesize the design.



Figure 2. Entity Diagram of 3x8 Decoder

After the design synthesis, create a simulation (testbench) file to the project. Simulate and verify the results. Show both a simulation log (standard output) and simulation waveform (timing diagram) in the laboratory report.



**Test Cases for Simulation:** Include ALL possible input combinations for **A** and vary the **E** values.

#### **Evaluation:**

| Level                           | 1.0                                                                                                                                                                                                                                                               | 2.0                                                                                                                                                                                                                                                             | 3.0                                                                                                                                                                                                                                                                      | 5.0                                                                                | Detino |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------|
| Criteria                        | Outstanding                                                                                                                                                                                                                                                       | Competent                                                                                                                                                                                                                                                       | Marginal                                                                                                                                                                                                                                                                 | Not Acceptable                                                                     | Rating |
| CO1: Verilog<br>Design Entry    | Verilog HDL description is correct and follows specified instructions.                                                                                                                                                                                            |                                                                                                                                                                                                                                                                 | Verilog HDL description is correct but DID NOT follow the specified instructions.                                                                                                                                                                                        | NO Verilog HDL<br>description is presented<br>or the design entry is<br>INCORRECT. |        |
| CO1: Design<br>Synthesis        | Verilog HDL description is<br>synthesized and compiled<br>with NO issues (with 0-1<br>warning). There is clear<br>evidence in the lab report<br>that supports this result.                                                                                        | Verilog HDL description is synthesized and compiled with MINOR issues on constructs (with 2-3 wamings). There is clear evidence in the lab report that supports this result.                                                                                    | Verilog HDL description is synthesized and compiled with MAJOR issues on constructs (with 4 or more warnings). There is evidence in the lab report that supports this result.                                                                                            | Simulation has FAILED or there is NO evidence showing a successful simulation.     |        |
| CO2: Verilog<br>Testbench Entry | Verilog HDL testbench is correct and follows specified instructions. ALL possible input combinations or AMPLE test stimuli are included to generate sufficient and verifiable output results.                                                                     |                                                                                                                                                                                                                                                                 | Verilog HDL testbench is correct but DID NOT follow specified instructions. Possible input combinations may be INCOMPLETE or test stimuli are NOT SUFFICIENT included to generate verifiable output results.                                                             | NO Verilog testbench is presented or INCOMPLETE.                                   |        |
| CO2: Functional<br>Verification | Simulation of the synthesized design is functional with NO issues and shows ALL correct and expected results. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE but are ALL correct. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE or there may be INCORRECT results. NO analysis is made with NO image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation has FAILED or there is NO evidence showing a successful simulation.     |        |

## For the laboratory report (LR #3), include the following items:

## • Exercise 3A: 2x4 Decoder

- Boolean function, logic diagram, and the respective solutions
- Label the logic diagram that corresponds to its Verilog design entry (names of I/O ports, internal signals, etc.)
- Proof of successful design synthesis (screenshot showing 0 errors)
- Proof of successful simulation results (screenshots of simulation results with annotations or discussion of results)

### Exercise 3B: 3x8 Decoder

 Internal block diagram with appropriate labels that corresponds to its Verilog design entry (names of I/O ports, internal signals, etc.)



- o Proof of successful design synthesis (screenshot showing 0 errors)
- Proof of successful simulation results (screenshots of simulation results with annotations or discussion of results)
- All Verilog files (.v) must be submitted along with LR #3